<!DOCTYPE html>
<html>
<meta charset="utf-8">
<head th:include="include :: header"></head>
<body class="gray-bg">
	<div class="wrapper wrapper-content ">
		<div class="col-sm-12">
			<div class="ibox">
				<div class="ibox-body">
					<div class="fixed-table-toolbar">
						<div class="columns pull-left">
							<button shiro:hasPermission="common:sysDict:add" type="button"
								class="btn  btn-primary" onclick="add()">
								<i class="fa fa-plus" aria-hidden="true"></i>添加
							</button>
							<button shiro:hasPermission="common:sysDict:batchRemove"
								type="button" class="btn  btn-danger" onclick="batchRemove()">
								<i class="fa fa-trash" aria-hidden="true"></i>删除
							</button>
							<button shiro:hasPermission="common:sysDict:edit"
									type="button" class="btn  btn-danger" onclick="updateDicTocache()">
								<i class="fa fa-trash" aria-hidden="true"></i>更新缓存
							</button>
						</div>
						<div class="columns pull-right">
							<button class="btn btn-success" onclick="reLoad()">查询</button>
						</div>
						<div class="columns pull-right col-md-2">
							<input id="searchName" type="text" class="form-control"
								placeholder="类型|描述">
						</div>
						<div class="columns pull-right col-md-2 nopadding">
							<select data-placeholder="选择类别" class="form-control chosen-select"
								tabindex="2" style="width: 100%">
								<option value="">选择类别</option>
							</select>
						</div>
					</div>
					<table id="exampleTable" data-mobile-responsive="true">
					</table>
				</div>
			</div>
		</div>
	</div>
	<!--shiro控制bootstraptable行内按钮看见性 -->
	<div>
		<script type="text/javascript">
			var s_edit_h = 'hidden';
			var s_remove_h = 'hidden';
			var s_resetPwd_h = 'hidden';
		</script>
	</div>
	<div shiro:hasPermission="common:sysDict:edit">
		<script type="text/javascript">
			s_edit_h = '';
		</script>
	</div>
	<div shiro:hasPermission="common:sysDict:remove">
		<script type="text/javascript">
			var s_remove_h = '';
		</script>
	</div>
	<div shiro:hasPermission="common:sysDict:add">
		<script type="text/javascript">
			var s_add_h = '';
		</script>
	</div>

	</div>
	<div th:include="include :: footer"></div>
	<script type="text/javascript">
        var prefix = "/common/sysDict"
        $(function() {

            //	var config = {
            //		'.chosen-select' : {},
            //		'.chosen-select-deselect' : {
            //			allow_single_deselect : true
            //		},
            //		'.chosen-select-no-single' : {
            //			disable_search_threshold : 10
            //		},
            //		'.chosen-select-no-results' : {
            //			no_results_text : '没有数据'
            //		},
            //		'.chosen-select-width' : {
            //			width : "95%"
            //		}
            //	}
            //	for (var selector in config) {
            //		$(selector).chosen(config[selector]);
            //	}
            load();
        });
        function selectLoad() {
            var html = "";
            $.ajax({
                url : '/common/sysDict/type',
                success : function(data) {
                    //加载数据
                    for (var i = 0; i < data.length; i++) {
                        html += '<option value="' + data[i].type + '">' + data[i].description + '</option>'
                    }
                    $(".chosen-select").append(html);
                    $(".chosen-select").chosen({
                        maxHeight : 200
                    });
                    //点击事件
                    $('.chosen-select').on('change', function(e, params) {
                        $('#exampleTable').bootstrapTable('refresh');
                    });
                }
            });
        }
        function load() {
            selectLoad();
            $('#exampleTable')
                .bootstrapTable(
                    {
                        method : 'get', // 服务器数据的请求方式 get or post
                        url : prefix + "/list", // 服务器数据的加载地址
                        //	showRefresh : true,
                        //	showToggle : true,
                        //	showColumns : true,
                        iconSize : 'outline',
                        toolbar : '#exampleToolbar',
                        striped : true, // 设置为true会有隔行变色效果
                        dataType : "json", // 服务器返回的数据类型
                        pagination : true, // 设置为true会在底部显示分页条
                        singleSelect : false, // 设置为true将禁止多选
                        // contentType : "application/x-www-form-urlencoded",
                        // //发送到服务器的数据编码类型
                        pageSize : 10, // 如果设置了分页，每页数据条数
                        pageNumber : 1, // 如果设置了分布，首页页码
                        //search : true, // 是否显示搜索框
                        showColumns : true, // 是否显示内容下拉框（选择显示的列）
                        sidePagination : "server", // 设置在哪里进行分页，可选值为"client" 或者 "server"
                        showToggle: true,//是否显示详细视图和列表视图的切换按钮
                        queryParamsType : "",
                        // //设置为limit则会发送符合RESTFull格式的参数
                        queryParams : function(params) {
                            return {
                                //说明：传入后台的参数包括offset开始索引，limit步长，sort排序列，order：desc或者,以及所有列的键值对
                                pageNumber : params.pageNumber,
                                pageSize : params.pageSize,
                                type : $('.chosen-select').val(),
                                searchName:$('#searchName').val()
                            };
                        },
                        // //请求服务器数据时，你可以通过重写参数的方式添加一些额外的参数，例如 toolbar 中的参数 如果
                        // queryParamsType = 'limit' ,返回参数必须包含
                        // limit, offset, search, sort, order 否则, 需要包含:
                        // pageSize, pageNumber, searchText, sortName,
                        // sortOrder.
                        // 返回false将会终止请求
                        responseHandler : function(res){
                            console.log(res);
                            return {
                                "total": res.data.total,//总数
                                "rows": res.data.records   //数据
                            };
                        },
                        columns : [
                            {
                                checkbox : true
                            },
                            {
                                field : 'type',
                                title : '类型'
                            },
                            {
                                field : 'description',
                                title : '描述'
                            },
                            {
                                field : 'name',
                                title : '标签名'
                            },
                            {
                                field : 'value',
                                title : '数据值',
                                width : '100px'
                            },
                            {
                                field : 'sort',
                                title : '排序'
                            },
                            {
                                title : '操作',
                                field : 'id',
                                align : 'center',
                                formatter : function(value, row, index) {
                                    var e = '<a class="btn btn-primary btn-sm ' + s_edit_h + '" href="#" mce_href="#" title="编辑" onclick="edit(\''
                                        + row.id
                                        + '\')"><i class="fa fa-edit"></i></a> ';
                                    var d = '<a class="btn btn-warning btn-sm ' + s_remove_h + '" href="#" title="删除"  mce_href="#" onclick="remove(\''
                                        + row.id
                                        + '\')"><i class="fa fa-remove"></i></a> ';
                                    var f = '<a class="btn btn-success btn-sm ' + s_add_h + '" href="#" title="增加"  mce_href="#" onclick="addD(\''
                                        + row.type +'\',\''+row.description
                                        + '\')"><i class="fa fa-plus"></i></a> ';
                                    return e + d +f;
                                }
                            } ]
                    });
        }
        function reLoad() {
            $('#exampleTable').bootstrapTable('refresh');
        }
        function add() {
            parent.layer.open({
                type : 2,
                title : '增加',
                maxmin : false,
                shadeClose : false, // 点击遮罩关闭层
                area : [ '800px', '520px' ],
                content : prefix + '/add' // iframe的url
            });
        }
        function edit(id) {
            parent.layer.open({
                type : 2,
                title : '编辑',
                maxmin : false,
                shadeClose : false, // 点击遮罩关闭层
                area : [ '800px', '520px' ],
                content : prefix + '/edit/' + id // iframe的url
            });
        }
        function remove(id) {
            layer.confirm('确定要删除选中的记录？', {
                btn : [ '确定', '取消' ]
            }, function() {
                $.ajax({
                    url : prefix + "/remove",
                    type : "post",
                    data : {
                        'id' : id
                    },
                    success : function(r) {
                        if (r.code == 0) {
                            layer.msg(r.msg);
                            reLoad();
                        } else {
                            layer.msg(r.msg);
                        }
                    }
                });
            })
        }

        function addD(type,description) {
            parent.layer.open({
                type : 2,
                title : '增加',
                maxmin : false,
                shadeClose : false, // 点击遮罩关闭层
                area : [ '800px', '520px' ],
                content : prefix + '/add/'+type+'/'+description // iframe的url
            });
        }
        function batchRemove() {
            var rows = $('#exampleTable').bootstrapTable('getSelections'); // 返回所有选择的行，当没有选择的记录时，返回一个空数组
            if (rows.length == 0) {
                layer.msg("请选择要删除的数据");
                return;
            }
            layer.confirm("确认要删除选中的'" + rows.length + "'条数据吗?", {
                btn : [ '确定', '取消' ]
                // 按钮
            }, function() {
                var ids = new Array();
                // 遍历所有选择的行数据，取每条数据对应的ID
                $.each(rows, function(i, row) {
                    ids[i] = row['id'];
                });
                $.ajax({
                    type : 'POST',
                    data : {
                        "ids" : ids
                    },
                    url : prefix + '/batchRemove',
                    success : function(r) {
                        if (r.code == 0) {
                            layer.msg(r.msg);
                            reLoad();
                        } else {
                            layer.msg(r.msg);
                        }
                    }
                });
            }, function() {});
        }

        function updateDicTocache(){
            var url = prefix+ "/updateDicTocache";
            $.ajax({
                url: url,
                dataType:"json",
                cache:false,
                async:false,
                success : function(data){
                    var flag = data.flag;
                    if(flag == "true"){
                        layer.msg("更新成功!");
                    }else{
                        layer.msg("更新失败!");
                    }
                }
            });
        }

	</script>
</body>
</html>